The Art of Multiprocessor Programming by Maurice Herlihy & Nir Shavit
Author:Maurice Herlihy & Nir Shavit
Language: eng
Format: epub
ISBN: 9780123977953
Publisher: Elsevier Inc.
Published: 2012-06-01T16:00:00+00:00
Figure 11.6 The LockFreeExchanger<T> Class.
Notice that the algorithm allows the inserted item to be null, something used later in the elimination array construction. There is no ABA problem because the compareAndSet() call that changes the state never inspects the item. A successful exchange’s linearization point occurs when the second thread to arrive changes the state from WAITING to BUSY (Line 34). At this point both exchange() calls overlap, and the exchange is committed to being successful. An unsuccessful exchange’s linearization point occurs when the timeout exception is thrown.
The algorithm is lock-free because overlapping exchange() calls with sufficient time to exchange will fail only if other exchanges are repeatedly succeeding. Clearly, too short an exchange time can cause a thread never to succeed, so care must be taken when choosing timeout durations.
Download
This site does not store any files on its server. We only index and link to content provided by other sites. Please contact the content providers to delete copyright contents if any and email us, we'll remove relevant links or contents immediately.
Coding Theory | Localization |
Logic | Object-Oriented Design |
Performance Optimization | Quality Control |
Reengineering | Robohelp |
Software Development | Software Reuse |
Structured Design | Testing |
Tools | UML |
Deep Learning with Python by François Chollet(11978)
Hello! Python by Anthony Briggs(9424)
OCA Java SE 8 Programmer I Certification Guide by Mala Gupta(9392)
The Mikado Method by Ola Ellnestam Daniel Brolund(9353)
Dependency Injection in .NET by Mark Seemann(8898)
Algorithms of the Intelligent Web by Haralambos Marmanis;Dmitry Babenko(7896)
Test-Driven iOS Development with Swift 4 by Dominik Hauser(7416)
Grails in Action by Glen Smith Peter Ledbrook(7333)
The Well-Grounded Java Developer by Benjamin J. Evans Martijn Verburg(7162)
Secrets of the JavaScript Ninja by John Resig Bear Bibeault(6007)
Kotlin in Action by Dmitry Jemerov(4688)
Practical Vim (for Kathryn Amaral) by Drew Neil(3748)
Cracking the GRE Premium Edition with 6 Practice Tests, 2015 (Graduate School Test Preparation) by Princeton Review(3626)
Linux Device Driver Development Cookbook by Rodolfo Giometti(3534)
Learn Windows PowerShell in a Month of Lunches by Don Jones(3279)
Becoming a Dynamics 365 Finance and Supply Chain Solution Architect by Brent Dawson(3197)
Microservices with Go by Alexander Shuiskov(2983)
Practical Design Patterns for Java Developers by Miroslav Wengner(2901)
Learning Java by Patrick Niemeyer & Daniel Leuck(2891)